<!DOCTYPE html>
<html>
  
<head>
  <meta charset="utf-8">
  <meta name="author" content="饿包子" />
  
  
  <title>前端面试题的收集和总结(进阶篇) | 饿包子博客</title>

  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">

  
    <meta name="keywords" content="面试合集," />
  

  
  <meta name="description" content="一些可能的面试题及项目的进阶应用，可能用到">

  
  
    <link rel="icon" href="/blog/images/xian.ico">
    <link rel="apple-touch-icon" href="/blog/images/Logo.png">
  

  
<link rel="stylesheet" href="/blog/css/Awesome.min.css">


  
<link rel="stylesheet" href="/blog/css/index.css">
<link rel="stylesheet" href="/blog/styles/components/highlight/highlight.css">


  
  
<script src="/blog/common/jquery.min.js"></script>

  
    
<script src="/blog/common/Av.min.js"></script>

  

  
    
<script src="/blog/common/MathJax.js"></script>

  

  
    
<script src="/blog/common/Valine.min.js"></script>

  

  

  <script>
  // theme-ad's config script
  // it can be used in every script
  
  window.AD_CONFIG = {
    leancloud: {"appid":"gE1EosDsVgB2slV4E92yPkcG-gzGzoHsz","appkey":"niR787UVTMyJQrR6gmOiJCKe","comment":true,"count":true},
    welcome: {"enable":false,"interval":30},
    start_time: "2018-06-10",
    passwords: ["a621ab606db2a11f63edc576a729843b8269250dc324206871d90635ac5e531c", ],
    is_post: true,
    lock: false,
    author: "饿包子",
    share: {"twitter":false,"facebook":false,"weibo":true,"qq":true,"wechat":false},
    mathjax: true,
    page_type: "",
    root: "/blog/"
  };
</script>

  
<script src="/blog/vendor/sha256.min.js"></script>
<script src="/blog/js/auth.js"></script>
<script src="/blog/js/index.js"></script>
<script src="/blog/vendor/qrcode.min.js"></script>


<meta name="generator" content="Hexo 5.4.2"></head>
  <body>
    <header class="site-header">
  <div class="site-header-brand">
    
      <span class="site-header-brand-title">
        <a href="/blog/">清风逐月</a>
      </span>
    
    
      <span class="site-header-brand-motto"> | 我思故我在</span>
    
  </div>
  <div class="site-header-right">
    <nav class="site-header-navigation">
      
        <a href="/blog/" target="_self">主页</a>
      
        <a href="/blog/archives/" target="_self">归档</a>
      
        <a href="/blog/tags/" target="_self">标签</a>
      
        <a href="/blog/categories/" target="_self">分类</a>
      
        <a href="/blog/categories/%E6%97%A5%E8%AE%B0" target="_self">日记</a>
      
    </nav>
    <div class="site-header-btn">
      
        <a href="https://github.com/lixianbin1/" target="_blank" id="site-github">
          <i class="fa fa-github-alt"></i>
        </a>
      
      <a href="javascript:void(0);" id="site-search">
        <i class="fa fa-search"></i>
      </a>
      <a href="javascript:void(0);" id="site-nav-btn">
        <i class="fa fa-ellipsis-v"></i>
      </a>
    </div>
  </div>
</header>
<nav class="table-content" id="site-nav">
  <div class="table-content-title">
    <span>导航</span>
  </div>
  <div class="table-content-main">
    <ol class="toc">
      
        <li class="toc-item">
          <a href="/blog/" target="_self">
            主页
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/archives/" target="_self">
            归档
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/tags/" target="_self">
            标签
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/categories/" target="_self">
            分类
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/categories/%E6%97%A5%E8%AE%B0" target="_self">
            日记
          </a>
        </li>
      
    </ol>
  </div>
</nav>
<div id="site-process"></div>
    <main>
      
  <div class="passage">
  <div class="passage-meta">
    <span>
      <i class="fa fa-calendar"></i>2022-08-29
    </span>
    
      <span>
        | <a href="/blog/categories/%E9%9D%A2%E8%AF%95%E5%90%88%E9%9B%86/"><i class="fa fa-bookmark"></i>面试合集</a>
      </span>
    
    
      <span>
        | <i class="fa fa-unlock-alt"></i>UNLOCK
      </span>
    
    <span>
       | <i class="fa fa-calendar"></i>更新时间:2022-8-29 17:35 
    </span>
  </div>
  <h1 class="passage-title">
    前端面试题的收集和总结(进阶篇)
  </h1>
  
  <article class="passage-article">
    <h2 id="进阶概念"><a href="#进阶概念" class="headerlink" title="进阶概念"></a>进阶概念</h2><h3 id="有了解什么是微前端吗，讲讲"><a href="#有了解什么是微前端吗，讲讲" class="headerlink" title="有了解什么是微前端吗，讲讲"></a>有了解什么是微前端吗，讲讲</h3><p>随着公司的发展，项目在不断增加，当需要对多个项目进行集成，集成成一个平台的时候，可以用到微前端，或者说一个大型项目，由多团队合作开发的时候，也可以用到微前端。微前端就是将一个项目拆分成多个更小更易管理的小应用，它们之间相互独立，又相互通信，它们可以独立发布功能，独立部署项目，同时又构建成一个项目。这就是微前端。有很多方法可以实现微前端，像iframe的嵌套，腾讯的wujie，阿里的qiankun等等。</p>
<h3 id="qiankun-的主应用和微应用之间的通讯"><a href="#qiankun-的主应用和微应用之间的通讯" class="headerlink" title="qiankun 的主应用和微应用之间的通讯"></a>qiankun 的主应用和微应用之间的通讯</h3><p>官方提供的action通讯，qiankun 内部提供了 initGlobalState 方法用于注册 MicroAppStateActions 实例的数据值用于通信； <code>setGlobalState</code>：设置 globalState - 设置新的值时，内部将执行 浅检查，如果检查到 globalState 发生改变则触发通知，通知到所有的 观察者 函数; <code>onGlobalStateChange</code>：注册 观察者 函数 - 响应 globalState 变化，在 globalState 发生改变时触发该 观察者 函数。 <code>offGlobalStateChange</code>：取消 观察者 函数 - 该实例不再响应 globalState 变化</p>
<h3 id="qiankun-的生命周期有哪些？"><a href="#qiankun-的生命周期有哪些？" class="headerlink" title="qiankun 的生命周期有哪些？"></a>qiankun 的生命周期有哪些？</h3><p>bootstrap、mount、unmount 这三个生命周期，代表着初始渲染只执行一次；每次进入都会调用；每次切换都会调用；</p>
<h3 id="qiankun-怎么实现样式隔离"><a href="#qiankun-怎么实现样式隔离" class="headerlink" title="qiankun 怎么实现样式隔离"></a>qiankun 怎么实现样式隔离</h3><p>在默认情况下，qiankun会沙盒模式会确保单实例场景子应用之间的样式隔离，但是无法确保主应用跟子应用、或者多实例场景的子应用样式隔离。可以在starts()方法中设置开启沙箱的严格的样式隔离，这种模式下 qiankun 会为每个微应用的容器包裹上一个 shadow dom 节点，从而确保微应用的样式不会对全局造成影响。也是设置样式前缀来保证样式名称直接的冲突覆盖问题；</p>
<h3 id="浅拷贝和深拷贝的区别，怎么实现深拷贝"><a href="#浅拷贝和深拷贝的区别，怎么实现深拷贝" class="headerlink" title="浅拷贝和深拷贝的区别，怎么实现深拷贝"></a>浅拷贝和深拷贝的区别，怎么实现深拷贝</h3><p>深拷贝和浅拷贝的区别只针对于像object和array之类的引用数据类型。像string和number之类的简单数据类型则不存在这种区别，对于浅拷贝来说就是简单的将对象复制一份出来，可以通过Object.assign()进行复制动作。而浅拷贝复制出来的对象。如果只有第一层属性，则没有问题，如果是多层对象，则从二层开始的对象起所引用的内存地址都是一个。这就会导致原对象修改里层对象会影响复制出新对象；然后深拷贝出来的对象则不管对象嵌套几层，都会复制出来，所复制的对象都有新的内存地址。而实现深拷贝，则可以使用JSON转换，简单通过JSON.parse(JSON.stringify(object)),这个方法的只能拷贝一些简单的。它不能拷贝对象里的函数。当层级很深的时候。可能会出现溢出现象。<br>然后可以通过递归循环去遍历各个属性然后判断属性类型，进行复制。可以引用第三插件进行设置。</p>
<h3 id="有了解数据埋点，有具体使用吗"><a href="#有了解数据埋点，有具体使用吗" class="headerlink" title="有了解数据埋点，有具体使用吗?"></a>有了解数据埋点，有具体使用吗?</h3><p>所谓“ 数据埋点 ”，是数据采集领域的术语，指的是针对特定用户行为或事件进行捕获、处理和发送的相关技术及其实施过程，用于业务分析，数字营销，产品运营等。主流埋点方案：第一种：自己公司研发在产品中注入代码统计，并搭建起相应的后台查询。比如：在点击按钮或者其他用户行为达到时候，请求1px图片或透明gif；通过后台进行数据统计。第二种：通过第三方统计工具，如友盟、神策、Talkingdata、GrowingIO等。</p>
<h3 id="为什么数据埋点请求要使用1px透明像素？"><a href="#为什么数据埋点请求要使用1px透明像素？" class="headerlink" title="为什么数据埋点请求要使用1px透明像素？"></a>为什么数据埋点请求要使用1px透明像素？</h3><p>能够完成整个 HTTP 请求+响应（尽管不需要响应内容）。触发 GET 请求之后不需要获取和处理数据、服务器也不需要发送数据，跨域友好，执行过程无阻塞；相比 XMLHttpRequest 对象发送 GET 请求，性能上更好<br>GIF的最低合法体积最小（最小的BMP文件需要74个字节，PNG需要67个字节，而合法的GIF，只需要43个字节）不会阻塞页面加载，影响用户的体验，只要new Image对象就好了；（排除JS/CSS文件资源方式上报）</p>
<h3 id="当一个函数的参数不确定的时候-怎么进行参数的读取"><a href="#当一个函数的参数不确定的时候-怎么进行参数的读取" class="headerlink" title="当一个函数的参数不确定的时候?怎么进行参数的读取"></a>当一个函数的参数不确定的时候?怎么进行参数的读取</h3><p>可以通过 arguments 进行参数的访问，<code>function add()&#123; console.log(arguments) &#125;;add(1,2,21)</code> </p>
<h3 id="什么是函数柯里化？"><a href="#什么是函数柯里化？" class="headerlink" title="什么是函数柯里化？"></a>什么是函数柯里化？</h3><p>函数柯里化是把接受多个参数的函数变换成接受一个单一参数（最初函数的第一个参数）的函数，并且返回接受余下的参数而且返回结果的新函数, js中bind() 就是函数柯里化的的实现</p>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br></pre></td><td class="code"><pre><span class="line">function add(a)&#123;</span><br><span class="line">    return function(b)&#123;</span><br><span class="line">       return a+b</span><br><span class="line">    &#125;</span><br><span class="line">&#125;</span><br><span class="line">add(1)(2)(3)</span><br></pre></td></tr></table></figure>

<h3 id="有了解什么是SSR吗？能讲一下嘛"><a href="#有了解什么是SSR吗？能讲一下嘛" class="headerlink" title="有了解什么是SSR吗？能讲一下嘛"></a>有了解什么是SSR吗？能讲一下嘛</h3><p>SSR 也就是服务端渲染，简单的讲就是将在客户端把标签渲染成HTML的工作放在服务端完成，然后再把html直接返回给客户端。SSR的优点在于可以加载的快速，白屏时间比CSR要短，SEO要比现在的单页面应用要好。 缺点在于开发和维护成本，开发条件会被限制。同时需要考虑服务器的部署和负载均衡。</p>
  </article>
  <aside class="table-content" id="site-toc">
  <div class="table-content-title">
    <i class="fa fa-arrow-right fa-lg" id="site-toc-hide-btn"></i>
    <span>目录</span>
  </div>
  <div class="table-content-main">
    <ol class="toc"><li class="toc-item toc-level-2"><a class="toc-link" href="#%E8%BF%9B%E9%98%B6%E6%A6%82%E5%BF%B5"><span class="toc-text">进阶概念</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%9C%89%E4%BA%86%E8%A7%A3%E4%BB%80%E4%B9%88%E6%98%AF%E5%BE%AE%E5%89%8D%E7%AB%AF%E5%90%97%EF%BC%8C%E8%AE%B2%E8%AE%B2"><span class="toc-text">有了解什么是微前端吗，讲讲</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#qiankun-%E7%9A%84%E4%B8%BB%E5%BA%94%E7%94%A8%E5%92%8C%E5%BE%AE%E5%BA%94%E7%94%A8%E4%B9%8B%E9%97%B4%E7%9A%84%E9%80%9A%E8%AE%AF"><span class="toc-text">qiankun 的主应用和微应用之间的通讯</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#qiankun-%E7%9A%84%E7%94%9F%E5%91%BD%E5%91%A8%E6%9C%9F%E6%9C%89%E5%93%AA%E4%BA%9B%EF%BC%9F"><span class="toc-text">qiankun 的生命周期有哪些？</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#qiankun-%E6%80%8E%E4%B9%88%E5%AE%9E%E7%8E%B0%E6%A0%B7%E5%BC%8F%E9%9A%94%E7%A6%BB"><span class="toc-text">qiankun 怎么实现样式隔离</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%B5%85%E6%8B%B7%E8%B4%9D%E5%92%8C%E6%B7%B1%E6%8B%B7%E8%B4%9D%E7%9A%84%E5%8C%BA%E5%88%AB%EF%BC%8C%E6%80%8E%E4%B9%88%E5%AE%9E%E7%8E%B0%E6%B7%B1%E6%8B%B7%E8%B4%9D"><span class="toc-text">浅拷贝和深拷贝的区别，怎么实现深拷贝</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%9C%89%E4%BA%86%E8%A7%A3%E6%95%B0%E6%8D%AE%E5%9F%8B%E7%82%B9%EF%BC%8C%E6%9C%89%E5%85%B7%E4%BD%93%E4%BD%BF%E7%94%A8%E5%90%97"><span class="toc-text">有了解数据埋点，有具体使用吗?</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E4%B8%BA%E4%BB%80%E4%B9%88%E6%95%B0%E6%8D%AE%E5%9F%8B%E7%82%B9%E8%AF%B7%E6%B1%82%E8%A6%81%E4%BD%BF%E7%94%A81px%E9%80%8F%E6%98%8E%E5%83%8F%E7%B4%A0%EF%BC%9F"><span class="toc-text">为什么数据埋点请求要使用1px透明像素？</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E5%BD%93%E4%B8%80%E4%B8%AA%E5%87%BD%E6%95%B0%E7%9A%84%E5%8F%82%E6%95%B0%E4%B8%8D%E7%A1%AE%E5%AE%9A%E7%9A%84%E6%97%B6%E5%80%99-%E6%80%8E%E4%B9%88%E8%BF%9B%E8%A1%8C%E5%8F%82%E6%95%B0%E7%9A%84%E8%AF%BB%E5%8F%96"><span class="toc-text">当一个函数的参数不确定的时候?怎么进行参数的读取</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E4%BB%80%E4%B9%88%E6%98%AF%E5%87%BD%E6%95%B0%E6%9F%AF%E9%87%8C%E5%8C%96%EF%BC%9F"><span class="toc-text">什么是函数柯里化？</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%9C%89%E4%BA%86%E8%A7%A3%E4%BB%80%E4%B9%88%E6%98%AFSSR%E5%90%97%EF%BC%9F%E8%83%BD%E8%AE%B2%E4%B8%80%E4%B8%8B%E5%98%9B"><span class="toc-text">有了解什么是SSR吗？能讲一下嘛</span></a></li></ol></li></ol>
  </div>
</aside>

  
  
    <aside class="passage-copyright">
      <div>本文作者: 饿包子</div>
      
        <div>
          原文链接: 
          <a href="" target="_blank">https://lixianbin1.github.io/blog/2022/08/29/%E3%80%90%E9%9D%A2%E8%AF%95%E9%9B%86%E9%94%A6%E3%80%91%E5%89%8D%E7%AB%AF%E9%9D%A2%E8%AF%95%E9%A2%98%E7%9A%84%E6%94%B6%E9%9B%86%E5%92%8C%E6%80%BB%E7%BB%93(%E8%BF%9B%E9%98%B6%E7%AF%87)/</a>
        </div>
      
      <div>
        版权声明: 本博客所有文章除特别声明外, 均采用 <a target="_blank" rel="noopener" href="https://creativecommons.org/licenses/by-nc-sa/4.0/">CC BY-NC-SA 4.0</a> 许可协议. 转载请注明出处!
      </div>
    </aside>
  
  
</div>

    </main>
    
    
<div class="site-footer-wrapper">
<!--
  <div class="footer-top">
    <a class="left" href="/blog/2022/09/19/%E3%80%90%E9%A1%B9%E7%9B%AE%E6%9E%84%E5%BB%BA%E3%80%91%E9%A1%B9%E7%9B%AE%E7%9A%84%E5%BC%80%E5%A7%8B%E5%92%8C%E6%8A%80%E6%9C%AF%E9%80%89%E5%9E%8B%E7%9B%B8%E5%85%B3/" data-enable="true">
      <i class="fa fa-arrow-left"></i>
    </a>
    <a class="right" href="/blog/2022/08/29/%E3%80%90%E6%AF%81%E4%BA%BA%E4%B8%8D%E5%80%A6%E3%80%91%E4%B9%BE%E5%9D%A4%E5%BE%AE%E5%BA%94%E7%94%A8%E7%9A%84%E5%BC%BA%E5%88%B6%E6%80%A7%E5%85%A5%E9%97%A8/" data-enable="true">
      <i class="fa fa-arrow-right"></i>
    </a>
  </div>
-->
  <footer class="site-footer">
    
      
        <div class="site-footer-col">
          <h5 class="site-footer-title">网站推荐</h5>
          
            <span class="site-footer-item">
              <a href="https://tympanus.net/codrops/" target="_blank">Codrops</a>
            </span>
          
            <span class="site-footer-item">
              <a href="http://taobaofed.org/" target="_blank">淘宝前端团队(FED)</a>
            </span>
          
        </div>
      
        <div class="site-footer-col">
          <h5 class="site-footer-title">文档教程</h5>
          
            <span class="site-footer-item">
              <a href="https://es6.ruanyifeng.com/" target="_blank">ES6入门</a>
            </span>
          
            <span class="site-footer-item">
              <a href="https://developer.mozilla.org/zh-CN/docs/Web" target="_blank">MDN Web文档</a>
            </span>
          
        </div>
      
        <div class="site-footer-col">
          <h5 class="site-footer-title">兴趣前沿</h5>
          
            <span class="site-footer-item">
              <a href="https://threejs.org/" target="_blank">threejs</a>
            </span>
          
            <span class="site-footer-item">
              <a href="https://github.com/justadudewhohacks/face-api.js" target="_blank">face-api</a>
            </span>
          
        </div>
      
    
    <div class="site-footer-info">
      <i class="fa fa-clock-o"></i> 本站已稳定运行<span id="site-time"></span>
    </div>
    
      <div class="site-footer-info">
        <i class="fa fa-paw"></i> 您是本站第 <span id="site-count"></span> 位访客
      </div>
    
    
      <div class="site-footer-info">
        <i class="fa fa-at"></i> Email: xianbin.me@qq.com
      </div>
    
<!--     <div class="site-footer-info">
      <i class="fa fa-copyright"></i> 
      2019 <a href="https://github.com/dongyuanxin/theme-ad/" target="_blank">Theme-AD</a>.
      Created by <a href="https://godbmw.com/" target="_blank">GodBMW</a>.
      All rights reserved.
    </div> -->
  </footer>
</div>
    <div id="site-layer" style="display:none;">
  <div class="site-layer-content">
    <div class="site-layer-header">
      <span class="site-layer-header-title" id="site-layer-title"></span>
      <i class="fa fa-close" id="site-layer-close"></i>
    </div>
    <div class="site-layer-body" id="site-layer-container">
      <div class="site-layer-input" id="site-layer-search" style="display: none;">
        <input type="text">
        <i class="fa fa-search"></i>
      </div>
      
        <div class="site-layer-reward" id="site-layer-reward" style="display: none;">
          
            <div>
              <img src="/blog/images/wechat.png" alt="WeChat">
              
                <p>WeChat</p>
              
            </div>
          
            <div>
              <img src="/blog/images/alipay.png" alt="AliPay">
              
                <p>AliPay</p>
              
            </div>
          
        </div>
      
      <div id="site-layer-welcome" style="display:none;"></div>
    </div>
  </div>
</div>
    

<div class="bottom-bar">

  <div class="bottom-bar-left">
<!--
    <a href="/blog/2022/09/19/%E3%80%90%E9%A1%B9%E7%9B%AE%E6%9E%84%E5%BB%BA%E3%80%91%E9%A1%B9%E7%9B%AE%E7%9A%84%E5%BC%80%E5%A7%8B%E5%92%8C%E6%8A%80%E6%9C%AF%E9%80%89%E5%9E%8B%E7%9B%B8%E5%85%B3/" data-enable="true">
      <i class="fa fa-arrow-left"></i>
    </a>
    <a href="/blog/2022/08/29/%E3%80%90%E6%AF%81%E4%BA%BA%E4%B8%8D%E5%80%A6%E3%80%91%E4%B9%BE%E5%9D%A4%E5%BE%AE%E5%BA%94%E7%94%A8%E7%9A%84%E5%BC%BA%E5%88%B6%E6%80%A7%E5%85%A5%E9%97%A8/" data-enable="true">
      <i class="fa fa-arrow-right"></i>
    </a>
-->
  </div>

  
  
  
  <div class="bottom-bar-right">
    <a href="javascript:void(0);" data-enable="true" id="site-toc-show-btn">
      <i class="fa fa-bars"></i>
    </a>
    
      <a href="#site-comment" data-enable="true">
        <i class="fa fa-commenting"></i>
      </a>
    
    <a href="javascript:void(0);" id="site-toggle-share-btn">
      <i class="fa fa-share-alt"></i>
    </a>
    
    <a href="javascript:void(0);" id="back-top-btn">
      <i class="fa fa-chevron-up"></i>
    </a>
  </div>
</div>
    <div id="share-btn">
  
  
  
    <a id="share-btn-weibo" href="javascript:void(0);" target="_blank">
      <i class="fa fa-weibo"></i>
    </a>
  
  
    <a id="share-btn-qq" href="javascript:void(0);" target="_blank">
      <i class="fa fa-qq"></i>
    </a>
  
  
</div>
    





    
  </body>
</html>